草庐IT

MongoDB 分片 + 复制

全部标签

mongodb - 如何在 Golang 中使用游标迭代时从 mongodb 记录中提取字段

我对golang编程和mongodb接口(interface)还很陌生。我有一个由另一个应用程序创建的记录数据库。我正在尝试遍历数据库并检查每条记录的特定字段。我可以将完整记录解码为bson,但我无法获取具体值。这个结构定义了我想要提取的3个字段:typemyDbaseRecstruct{aidstring`bson:"pon-util-aid"`ingressPctstring`bson:"ingress-bucket-percent"`egressPctstring`bson:"egress-bucket-percent"`}这是我的代码,用于在collection.Find(ct

mongodb - 为什么我的更新函数返回新查询但不更新数据库?

我正在创建一个RESTfulAPI,并且正在创建一个更新函数。我使用FindOneAndUpdate,它实际上并没有更新数据库。我尝试了很多东西,但我对这门语言还很陌生,所以我有点迷茫。funcUpdateCompanyEndpoint(responsehttp.ResponseWriter,request*http.Request){response.Header().Set("content-type","application/json")params:=mux.Vars(request)name,_:=params["name"]varcompanyCompany_=json.

mongodb - 模拟官方 MongoDb 驱动程序

我需要定义这些接口(interface)来模拟官方的mongo驱动typeMgCollectioninterface{FindOne(ctxcontext.Context,filterinterface{},opts...*options.FindOneOptions)*mongo.SingleResult//Othermethods}typeMgDatabaseinterface{Collection(namestring,opts...*options.CollectionOptions)MgCollection//Othermethods}在mongo驱动包中有两个结构mongo

Mongodb unix 套接字与官方 mongo-go-driver 的连接?

找不到任何关于unix域套接字连接支持官方mongo-go-driver的信息。它是否得到官方实现和支持?“mongodb:///tmp/mongodb-27017.sock”uri不起作用。 最佳答案 Isitimplementedandsupportedofficially?使用官方MongoDBGodriver您可以直接连接到URI套接字。您只需要转义斜线即可。例如使用v1.1+:mongoURI:="mongodb://%2Ftmp%2Fmongodb-27017.sock"client,err:=mongo.NewClie

go - 使用 goroutines 复制子目录

我的程序将多个文件和目录从计算机的不同部分复制到一个地方。其中一个目录很大,所以复制它大约需要20-30秒。现在我只是制作了这个方法,它复制该目录以作为goroutine启动:funcCopySpecificDirectory(source,deststring,quitchanint)(errerror){files,err:=os.Open(source)file,err:=files.Readdir(0)iferr!=nil{fmt.Printf("Errorreadingdirectory%s:%s\n",source,err)returnerr}for_,f:=rangefi

mongodb - Go/Mgo -> MongoDB 中的 []byte,不可寻址数组的 slice

我得到一个:reflect.Value.Slice:sliceofunaddressablearray当我尝试使用mgo将sha256哈希添加到mongoDB时出错。其他[]bytes工作正常。hash:=sha256.Sum256(data)err:=c.Col.Insert(bson.M{"id":hash})知道问题出在哪里吗?我知道我可以将散列编码为字符串,但这不是必需的。 最佳答案 该错误意味着bson将hash视为[]byte,但它实际上是[32]byte。后者是一个数组值,不能使用reflect包对数组值进行slice

go - 为 MongoDB 查找查询解析没有固定键集的字符串

我有一个API,用户可以在其中传递他们想要传递给MongoDB的查询参数。API将从请求参数中获取字符串并将其直接传递给Mongo查找查询。查询字符串不会有任何固定的键集。它可以具有以下结构之一-{"name":"foo"}{"name":"foo","source":"bar"}{"source":"oof","place":"rab"}...如何解析这个字符串,这样我就可以直接使用了——collection.Find(MyQuery).All(&m) 最佳答案 您只需在json上使用json.Unmarshal并将其转换为bso

mongodb - 谷歌应用引擎 : One To Many relations in Go

我目前正在决定将哪个堆栈用于(小型)社交网络。我很乐意在GoogleAppEngine上用golang编写代码,因为这会产生干净、快速的代码,并具有现代云服务和托管的所有优势。您将如何在GAE中使用golang实现一对多和/或多对一关系?根据文档,您可以在数据存储结构中使用自己的类型,只要它们的属性是文档中提到的那些。例如:typeCommentstruct{TitlestringTextstringUser*User}typePhotostruct{DescriptionstringComments[]*Comment}我认为应该工作,我是对的吗?如果我是对的,我怎么能:a)在一次查

json - Go:在json响应中从数据库复制各种类型的数据

我正在尝试从我的数据库中获取一组数据并以json格式返回它们。但是,它们的类型不同,我似乎在我的代码中使用了错误的返回类型。开始:typeScriptstruct{Idint`json:"id"`Typestring`json:"type"`Created_atint`json:"created_at"`}typeAllContentstruct{New_content[]*Script`json:"new_content,omitempty"`}funcReadAllContent()[][]interface{}{err:=db.Ping()iferr!=nil{log.Fatal

go - go1.4中是否有必要放弃堆栈上太大的变量以避免堆栈复制?

我们知道,在go1.4中,goroutine的栈可以通过复制栈来增加。我的问题是,是否有必要在go中避免堆栈上的局部变量太大?例如funcfoo(){varbuf[8096]int//dosomethingwithbuf}或varbuf[8096]intfuncfoo(){//dosomethingwithbuf}我的意思是,是否有必要使用后一个示例来避免由于堆栈复制而导致的大变量? 最佳答案 堆栈几乎总是比堆快。在哪里定义变量更多的是关于范围。由于在后一个示例中Go是词法范围语言,因此您弄脏了全局命名空间,使varbuf在程序的任